<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <script type="text/javascript" src="../../js/jquery-2.1.1.min.js"></script>
    <style>
        #OText{
            width:500px;
            height:500px;
        }
    </style>
</head>
<body>
<textarea id="OText">4月13日消息，据台湾媒体报道，32岁的孙燕姿(Sng Ee Tze)和后天将满34岁的荷兰籍印度尼西亚男友纳迪姆(Nadim Van Der Ros)交往5年，
    曾说过"有空就结婚"的她，果然趁着宣传期尾声，于3月31日在新加坡登记注册了！昨消息传开，她未否认，仅说会选择适当时间公布喜讯，所属"美妙音乐"则表示她个性低调，
    婚礼只会邀请双方亲友，也不会透露细节，但据新加坡可靠消息指出，婚宴订在5月初。</textarea>
<button id="button">选中一些文字，然后点击本按钮</button>
</body>
<script>
    $('#button').click(function(){
        getCaretForTextArea('OText');
    });

    function getCaretForTextArea(ZysrID){
        var txb = document.getElementById(ZysrID);//根据ID获得对象

        var pos = 0;//设置初始位置
        txb.focus();//输入框获得焦点,这句也不能少,不然后面会出错,血的教训啦.
        var s = txb.scrollTop;//获得滚动条的位置
        var r = getSelectedText();//创建文档选择对象
        var t = txb.createTextRange();//创建输入框文本对象
        t.collapse(true);//将光标移到头
        t.select();//显示光标,这个不能少,不然的话,光标没有移到头.当时我不知道,搞了十几分钟
        var j = getSelectedText();//为新的光标位置创建文档选择对象
        r.setEndPoint('StartToStart',j);//在以前的文档选择对象和新的对象之间创建对象,妈的,不好解释,我表达能力不算太好.有兴趣自己去看msdn的资料
        var str = r.text;//获得对象的文本
        var re = new RegExp('[//n]','g');//过滤掉换行符,不然你的文字会有问题,会比你的文字实际长度要长一些.搞死我了.我说我得到的数字怎么总比我的实际长度要长.
            str = str.replace(re,'');//过滤
        pos = str.length;//获得长度.也就是光标的位置
        alert(pos);
        r.collapse(false);
        r.select();//把光标恢复到以前的位置
        txb.scrollTop = s;//把滚动条恢复到以前的位置
    }

    function getSelectedText() { //this function code is borrowed from: http://www.codetoad.com/javascript_get_selected_text.asp

        var txt = "";
        if (window.getSelection) {
            txt = window.getSelection();
        } else if (window.document.getSelection) {
            txt = window.document.getSelection();
        } else if (window.document.selection) {
            txt = window.document.selection.createRange().text;
        }
        return txt;
    }
</script>
</html>